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RECORDING APPARATUS 

5 BACKGROUND OF THE INVENTION 
Technical Field 

[0001] The present invention relates to technology for 

accessing a semiconductor memory according to instructions of 
10 an accessing apparatus, in particular to technology for 
performing the access in accordance with the amount of current 
that can be applied by the accessing apparatus. 
Background Art 

[0002] Since being compact , light and slim and allowing easy 

15 manipulation, SD cards and other memory cards equipped with 
flash memories therein are widely employed in digital 
apparatuses such as digital still cameras. The storage 
capacities of commercially available memory cards are in general 
from 16 to 512 MB, and the recording rates are up to 10 MB/s 
20 or so. 

For recording data with large storage space requirements, 
such as video and audio data in DV format, however, the above 
storage capacities and recording rates are not sufficient. In 
the case of data with a reproduction rate of 4 MB/s, for example, 
25 only two-minute' s worth of data can be recorded, and the writing 
process takes about one minute. 

[0003] In order to solve these problems, Patent References 

1 and 2 disclose memory card drives capable of mounting multiple 

1 



memory cards thereon. According to the disclosed technology, 
a large storage capacity is attained by using more than one 
memory card placed in a memory card drive. In addition, an 
improvement in the recording rate is achieved by writing data 
5 into multiple memory cards in parallel using striping, which 
is known as one of the RAID formats. 

[0004] In the case of using such a memory card drive 

connected to a personal computer (hereinafter, "PC") or another 
electric apparatus, the amount of the current that the electric 

10 apparatus is able to supply to the memory card drive differs 
from one electric apparatus to another. When it comes to PCs, 
for example, the current that can be supplied by a PC to a memory 
card drive is defined in the PC card standard as 1 A. However, 
the available supply current practically varies among types of 

15 PCs due to their heat release characteristics and the like. 
[0005] When two or more memory cards are operated in 

parallel using a memory card drive, the consumption current of 
the memory card drive increases in proportion to the number of 
memory cards in operation. Operating four memory cards each 

20 having a consumption current of 200 mA, for instance, claims 
a total consumption current of 800 mA. Accordingly, PCs 
applicable to this memory card drive are limitd only to those 
feasible to supply 800 mA or more current to the memory card 
drive . 

25 <Patent Reference 1> Japanese Laid-open Patent Application 

Publication No. 2002-189992 

<Patent Reference 2> Japanese Laid-open Patent Application 
Publication No. 2000-207137 



Bjrg cloQurc of the I - nv e ntio fl— SUMMARY OF THE INVENTION 
[Problem that the Invention is to Solve] 

[0006] However, it is inconvenient for users that 

5 connectable electric apparatuses are limited according to their 
available supply current, and there has been a call for an 
applicable memory card drive independent of the amount of 
current able to be supplied by an electric apparatus to which 
the memory card drive is connected. The present invention has 

10 been made in view of the problem above, and aims at offering 
a recording device and a memory card drive device capable of 
changing their operating conditions according to the amount of 
current that can be supplied by an electric apparatus to which 
the recording device or the memory card drive device is connected, 

15 and controlling their consumption current to be at or below the 
available supply current of the electric apparatus. 
_[Mcana to Solve the Problem] 

[0007] In order to achieve the above stated objective, the 

present invention is a recording device comprising: one or more 

20 semiconductor memories; an obtaining unit operable to obtain 
an upper limit of current to be supplied from an accessing 
apparatus to the recording device; a command obtaining unit 
operable to obtain from the accessing apparatus at least one 
command, a type of which is one of a write command instructing 

25 data writing to the semiconductor memories and a read command 
instructing data reading from the semiconductor memories; an 
access unit operable to receive current supply from the 
accessing apparatus and access the semiconductor memories 

3 



according to a control signal; and a control unit operable to 
calculate an access upper limit by subtracting the amount of 
current consumed by individual units other than the 
semiconductor memories and the access unit from the upper limit , 
5 set operating conditions of the access unit and the 
semiconductor memories according to the type of the obtained 
command, using the access upper limit, generate the control 
signal based on the obtained command and the operating 
conditions, and output the control signal. 

10 [0008] The control unit here corresponds to a parallel 

control unit, a control information storage unit and a clock 
control unit in the embodiments hereinafter described. In 
addition, the control signal corresponds to a write direction, 
a read direction and a clock signal. 

15 [Advantageous Effects of the Invention] 

[0009] According to the structure above, the recording 

device of the present invention sets the operating conditions 
based on the access upper limit which is calculated from the 
upper limit obtained from the accessing apparatus . Accordingly, 

20 by setting appropriate operating conditions, the present 
invention enables access to the semiconductor memories, 
requiring electric current no more than the amount supplied by 
the accessing device. 

The recording device above is characterized by: the 

25 control unit prestoring therein a current consumption value 
representing the amount of current consumed by the access unit 
and the semiconductor memories, with respect to each type of 
the write and the read commands, and setting the operating 



conditions corresponding to the type of the obtained command 
using the access upper limit and the current consumption value. 
[0010] According to the structure above, the control unit 

sets operating conditions corresponding to the command. That 
5 is, in the case when the electric power consumed by the 
semiconductor memories and access unit varies depending on a 
command output from the accessing device, the control unit is 
capable of setting the best suited operating conditions with 
respect to each command. This enables the access unit to access 
10 the semiconductor memories on the most appropriate operating 
conditions for each command. 

[0011] The recording device above is characterized by : the 

control unit setting the operating conditions so that cause a 
parallel -operation count of memories out of the semiconductor 

15 memories to operate in parallel, and outputting to the access 
unit the control signal generated based on the obtained command 
and the operating conditions, and instructing access to the 
parallel-operation count of memories; and the access unit 
accesses the parallel-operation count of memories. Here, the 

20 parallel-operation count is smaller than or equal to number of 
pieces of all the semiconductor memories. 

[0012] According to the structure above, the control unit 

sets the operating conditions so that the parallel -operation 
memories, which are selected from among the semiconductor 
25 memories of the recording device, operate in parallel. Here, 
the number of the parallel-operation memories matches the number 
of all or some of the semiconductor memories. That is, the 
number of semiconductor memories for parallel operations is 



limited . The amount of current consumed by the recording device 
corresponds to the number of semiconductor memories in the 
parallel operations. Therefore, limiting the number of 
semiconductor memories for the parallel operations guarantees 
5 reliable restriction of the amount of current consumed by the 
recording device. 

[0013] The recording device above is characterized by : the 

current consumption value representing the amount of current 
consumed by the access unit and the semiconductor memories for 

10 causing one of the semiconductor memories to operate; and the 
control unit calculating, as the parallel -operation count, a 
quotient obtained by dividing the access upper limit by the 
current consumption value. 

According to the structure above, the control unit is able 

15 to readily work out the number of parallel -operation memories 
by calculating a quotient, which is obtained by dividing the 
access upper limit by the consumption current value. 
[0014] The recording device above is characteri zed by : the 

access unit including as many access subunits as the 

20 semiconductor memories, and each of the access subunits 
corresponding to a different one of the semiconductor memories; 
the control unit generating the control signal that includes 
as many access signals as the paral lei -operation count of 
memories; each of the access signals being for instructur ing 

25 a different one of the access subunits to access a corresponding 
semiconductor memory thereof; the control unit outputting each 
of the access signals to a corresponding one of the access 
subunits; and access subunits that received the access signals 



accessing corresponding semiconductor memories according to 
the received access signals. 

[0015] According to the structure above, the control unit 

outputs each access signal to a different one of the access 
5 subunits, and the access subunits that received the access 
signals have access to the corresponding semiconductor memories . 
Therefore, sequentially outputting access instructions to the 
respective access units enables data to be written to the 
semiconductor memories of the recording device in rotation, 

10 which allows the respective semiconductor memories to store 
therein a more or less even amount of data. This avoids a 
reduction in the number of semiconductor memories operable in 
parallel. Accordingly, a decrease in access speed of the 
recording device can be prevented. 

15 [0016] The recording device of the present invention is 

characterized by: the control unit setting the operating 
conditions that cause the semiconductor memories to operate at 
a memory frequency which is no more than a maximum operating 
frequency of the semiconductor memories, generating a clock 

20 signal having the same frequency as the memory frequency based 
on the command and the operating conditions, and outputting to 
the access unit the control signal including the generated clock 
signal; and the access unit outputting the clock signals 
received from the control unit to the semiconductor memories 

25 and has access to the semiconductor memories. 

[0017] According to the structure above, the access unit 

outputs to the semiconductor memories the clock signal having 
a frequency no more than the maximum operating frequency of the 



semiconductor memories, and accesses the semiconductor 
memories. Since the semiconductor memories operate in 
accordance with the clock signal received from the access unit, 
the operating frequency of the semiconductor memories can be 
5 set low by reducing the frequency of the clock signal. The 
operating frequency of the semiconductor memories is 
proportional to the consumption current value of the 
semiconductor memories and the access unit. As a result, the 
consumption current of the recording device can be suppressed 

10 to the upper limit or lower by setting the memory frequency based 
on the access upper limit and changing the operating frequency 
of the semiconductor memories into the memory frequency. 
[0018] The recording device of the present invention is 

characterized by: the control unit prestoring therein, as the 

15 current consumption value, a maximum current value which 
represents the amount of current consumed by the access unit 
and the semiconductor memories when each of the semiconductor 
memories operate at the maximum operating frequency, and 
calculating the memory frequency using the access upper limit 

20 and the ratio of the maximum operating frequency to the maximum 
current value. 

According to the structure above, the control unit can 
readily calculate the operating frequency using the access upper 
limit and the ratio of the maximum operating frequency to the 

25 maximum current value . 

[0019] The recording device of the present invention above 

is characterized by: the control unit prestoring therein the 
maximum operating frequency together with the maximum current 



value . 

According to the structure above, the control unit 
prestores the maximum operating frequency together with the 
maximum current value, and is therefore able to calculate the 
5 operating frequency promptly. 

In addition, the control unit prestores therein the 
current consumption value associated with the read command, and 
sets the operating conditions the semiconductor memories to 
operate at the memory frequency in response to the command. 

10 [0020] According to the structure above, the control unit 

sets the operating conditions so that the semiconductor memories 
operate at the memory frequency in response to the command 
instructing data reading, and the semiconductor memories 
perform reading operations at the operating frequency which is 

15 the same as the memory frequency . To write data to semiconductor 
memories requires injection of a specific amount of electrons, 
and there is no correlation between the frequency and the amount 
of current consumed. Accordingly, as to writing operations, 
changing the operating frequency does not lead to a reduction 

20 in the consumption current. Here, the amount of consumption 
current can be reduced by performing the reading operations at 
the memory frequency when a command instructing data reading 
has been received from the accessing device. 

[0021] The recording device of the present invention is 

25 characterized by: the control unit including a frequency 
divider, generating the clock signal having the same frequency 
as the memory frequency using the frequency divider, and 
outputting the control signal each including the generated clock 



signal . 

According to the structure above, the control unit is 
capable of readily changing the frequency of the clock signal 
using the frequency divider. 
5 (0022] In addition, the control unit may include a PLL 

(Phase Lock Loop) , generate the clock signal having the same 
frequency as the memory frequency using the PLL, and output the 
control signal including the generated clock signal. 

According to the structure above, the control unit can 

10 continuously change the frequency of the clock signal using the 
PLL. As a result, the control unit is capable of generating 
and outputting the clock signal having the best suited frequency 
for the access upper limit and the command obtained by the 
command obtaining unit. 

15 [0023] The recording device of the present invention is 

characterized by: the control unit setting, as the operating 
conditions, a 1st operating condition that causes a 
parallel -operation count of memories out of the semiconductor 
memories operate in parallel and a 2nd operating condition that 

20 causes the semiconductor memories to operate at an operating 
frequency no more than a maximum operating frequency of the 
semiconductor memories, adopting at least one of the 1st and 
2nd operating conditions based on the type of the obtained 
command, and generating the control signal based on the adopted 

25 operating condition. 

[0024] According to the structure above, the control unit 

adopts at least one of the 1st and 2nd operating conditions, 
and outputs the control signals based on the adopted operating 



condition. Thus, by changing one or both of the number of 
parallel -operation memories and the operating frequency of the 
semiconductor memories, the control unit is capable of setting 
the most appropriate operating conditions while keeping the 
5 required amount of electric current within the access upper 
limit. Therefore, the access unit can have access to the 
semiconductor memories at high speed, making best use of the 
current no more than the access upper limit. 

[0025] The semiconductor memories of the recording device 

10 of the present invention may be flash memories. Flash memories 
are today widely in use and a lot of practical achievements in 
producing flash memories have already been made. Therefore, 
the recording device having the above-mentioned structure can 
easily be produced. The semiconductor memories of the 
15 recording device of the present invention may be nonvolatile 
magnetic memories. 

[0026] Nonvolatile magnetic memories enables high-speed 

data input and output. At the same time, data is retained by 
not electric charge but electron spin, which results in a 

20 semipermant record retention time. According to the structure 
above, the recording device has excellent record retention 
performance and allows for higher-speed data access. 

The recording device of the present invention is 
characterized by: the obtaining unit obtaining the upper limit 

25 by a Set Features command complying with ATA {AT Attachment) 
standard. 

[0027] According to the structure above, the recording 

device of the present invention is applicable to various 



electric apparatuses complying with the ATA standard. 

The recording device of the present invention is 
characterized by: the semiconductor memories being portable 
and detachable from the recording device ; and the obtaining unit , 
5 the access unit and the control unit makeing up a memory card 
drive device for reading and writing information from/to the 
semiconductor memories. 

[0028] According to the structure above, the recording 

device comprises portable semiconductor memories and a memory 

10 card drive device. Thus, the memory card drive device allows 
for high-speed data input and output, using existing, 
commercially available memory cards as the portable 
semiconductor memories. 

The recording device of the present invention is 

15 characterized by: the control unit outputting the control 
signal including a clock signal; and the access unit supplying 
the clock signal only to one or more of the semiconductor 
memories being accessed, and stopping supply of the clock signal 
to remaining one or more of the semiconductor memories being 

20 not accessed. 

[0029] According to the structure above, the access unit 

stops supply of the clock signal to semiconductor memories being 
currently not accessed, in the case where existing memory cards 
are used as the portable semiconductor memories, each of the 

25 memory cards generally includes a control unit and a storage 
unit. Even if not receiving a request for access to data, the 
control units of the memory cards carry out predefined 
operations when receiving the clock signal and consume electric 



power. Therefore, the access unit stops the supply of the clock 
signal to the memory cards being currently not accessed, which 
leads to a cut in the power consumption by the amount otherwise 
consumed by the control units of these nonaccessed memory cards . 
5 [Brief De s cript io n of the Drawinga] BRIEF DESCRIPTION OF THE 
DRAWINGS 

[0030] FIG. 1 shows an example of the use of a memory card 

3 00 ; 

FIG. 2 is a block diagram showing a structure of a video 
10 camera 200; 

FIG. 3 is a block diagram showing a structure of a PC 100; 

FIG. 4 shows an example of a structure of an ATA command 
given and received between the PC 100 and the memory card 300 ; 

FIG. 5 is a block diagram showing a structure of the memory 
15 card 300; 

FIG. 6 is a block diagram showing a structure of a parallel 
control unit 304 ; 

FIG. 7 is a flowchart showing operations of the memory card 
300 and PC 100 when the memory card 300 is placed in the PC 100; 
20 FIG. 8 is a flowchart showing data write operations of the 

memory card 300 and PC 100; 

FIG. 9 is another flowchart showing data write operations 
of the memory card 300 and PC 100 (continued from FIG. 8); 

FIG. 10 is a time chart showing operations of respective 
25 flash memories when data is written to the memory card 3 00; 

FIG. 11 is a block diagram showing a structure of a memory 
card 600 according to Embodiment 2; 

FIG. 12 is a block diagram showing a structure of a parallel 



control unit 604; 

FIG. 13 is a flowchart showing operations of the memory 
card 600 and PC 100 when the memory card 600 is placed in the 
PC 10 0; 

5 FIG . 14 is a flowchart showing data read operations of the 

memory card 60 0 and PC 10 0; 

FIG. 15 is a time chart showing the data read operations 
of the memory card 600 and PC 100; 

FIG. 16 shows an example of the use of a memory card drive 

10 700; 

FIG. 17 is a block diagram showing a structure of the memory 
card drive 700; and 

FIG. 18 is a block diagram showing a structure of a parallel 
control unit 704. 
15 [Explanation of References] 
[0031] 100 PC 

200 video camera 

300 memory card 

301 external IF unit 
20 302 control unit 

303 command analysis unit 

304 parallel control unit 

305 clock control unit 

308 control information storage unit 
25 309 buffer memory 

310-313 flash memory 

321 command execution unit 

600 memory card 

14 



700 memory card drive 
[BC3t Mod e for ■■ Carrying-Out -the Invention] DETAILED DESCRIPTION 
OF THE INVENTION 

[0032] Detailed descriptions of embodiments according to 

5 the present invention are given below with the aid of drawings. 
1 . EMBODIMENT 1 

A memory card 300 of Embodiment 1 is used while being set 
in a PC 100 or a video camera 200 as shown in FIG. 1. 

The video camera 200 generates audio and image data and 
10 records the generated audio and image data in the memory card 
300 . 

[0033] The PC 100 is connected to a display 140 and a 

keyboard 150, and plays or edits data stored in the memory card 
300 according to the user's operation. 

15 The memory card 300 is equipped with four flash memories. 

The memory card 30 0 obtains a value representing the maximum 
current that an external apparatus — specifically speaking, the 
PC 10 0 or video camera 200 — can supply to the memory card 300 
(hereinafter, referred to as "available supply current value" ) , 

20 and calculates, based on the obtained available supply current 
value, how many flash memories are operable in parallel. The 
memory card 300 causes the calculated number of flash memories 
to operate in parallel in response to a command from the PC 100. 
1.1 Video Camera 200 

25 The video camera 200 comprises, as shown in FIG. 2: an 

input and output unit 201; a power unit 202 ; an image conversion 
unit 203 ; an image pickup unit 204; a control unit 207; an input 
unit 212; and a reproduction unit 213. 



[0034] The video camera 200 includes, concretely speaking, 

a microprocessor, a RAM and a ROM. Computer programs are stored 
in the RAM and ROM. The microprocessor operates according to 
the computer programs , and thereby the video camera 200 fulfills 
5 its function. 

{1) Power Unit 202 

The power unit 202 supplies electric power from batteries 
or an external source to each circuit constituting the video 
camera 200. The power unit 202 also supplies electric power 
10 to the memory card 3 00 via the input and output unit 201. 

(2) Available Supply Current Value Storage Unit 210 
The available supply current value storage unit 210 is 

constituted with a ROM, and stores an available supply current 
value therein. The available supply current value is a value 
15 indicating an upper limit of current that the video camera 200 
is capable of supplying to the memory card 300. 

(3) Input and Output Unit 201 

The input and output unit 201 is connected to the memory 
card 3 00, and performs input and output of various information 
20 between the control unit 207 and the memory card 300. 

[0035] in addition, the input and output unit 201 supplies 

power from the power unit 202 to the memory card 300. 

(4) Image Pickup Unit 204 and Image Conversion Unit 203 
The image pickup unit 204 comprises optical lenses, color 

25 filters, CCDs (Charge Coupled Devices) and the like, and 
generates image data by converting incident light into electric 
charges . 

The image conversion unit 203 compresses image data 



generated by the image pickup unit 204, using DCT (Discrete 
Cosine Transform) — one of the orthogonal conversion, 
quantization, motion compensation, variable length coding, or 
the like. 
5 (5) Control Unit 207 

The control unit 207 controls operations of individual 
units constituting the video camera 200. 

[0036] The control unit 207 also detects, via the input and 

output unit 201, the memory card 300 being set in the video camera 

10 200. When detecting the memory card 300, the control unit 207 
implements a configuration process including allocation of 
drives and memory space. 

After completing the configuration process, the control 
unit 207 gives and receives information concerning power 

15 management, using the available supply current value stored in 
the available supply current value storage unit 210. Such 
initialization processes between the memory card 300 and a 
device in which the memory card 300 is set are explained in detail 
hereinafter . 

20 (6) Input Unit 212 

The input unit 212 is equipped with a variety of buttons 
and the like, detects a user's operation, and outputs to the 
control unit 207 operation directing information that indicates 
the detected operation. 

25 (7) Reproduction Unit 213 

The reproduction unit 213 includes a decoder and a liquid 
crystal display, expands compressed image data, generates a 
screen and presents the generated screen on the liquid crystal 



display . 

1.2 PC 100 

The PC 100 comprises, as shown in FIG. 3: an external IF 
unit 101; an available supply current value storage unit 110; 
5 an information storage unit 111; an input control unit 112; and 
a display control unit 113 . 

[0037] The PC 100 is, specifically speaking, a computer 

system including a microprocessor, a RAM and a ROM. Computer 
programs are stored in the RAM, ROM and information storage unit 
10 111. The microprocessor operates according to the computer 
programs, and thereby the PC 100 fulfills its function. 

(1) Power Supply Unit 105 

The power supply unit 105 supplies electric power to each 
circuit constituting the PC 100 . The power supply unit 105 also 
15 supplies electric power to the memory card 300 via the external 
IF unit 101. 

(2) Available Supply Current Value Storage Unit 110 and 
Information Storage Unit 111 

The available supply current value storage unit 110 is 
20 constituted with a ROM, and stores therein an available supply 
current value Iok. The available supply current value Iok is 
a value indicating an upper limit of current that the PC 100 
can supply to the memory card 300. 

[0038] The information storage unit 111 is constituted with 

25 a hard disk unit, and stores therein a variety of data, computer 
programs and the like. 

(3) External IF Unit 101 

The external IF unit 101 is connected to the memory card 



300, and performs input and output of various information 
between the control unit 107 and the memory card 300. 
[0039] In addition, the external IF unit 101 supplies power 

from the power supply unit 105 to the memory card 300. 
5 (4) Control Unit 107 

The control unit 107 controls operations of individual 
units constituting the PC 100. 

The control unit 107 detects the memory card 3 00 via the 
external IF unit 101. 

10 In addition, the control unit 107 receives, from the input 

control unit 112, operation directing information 
corresponding to the key operation of the user. 
[0040] (4-1) Initialization 

When detecting the memory card 300, the control unit 107 

15 implements a configuration process including allocation of 
drives and memory space. 

After completing the configuration process, the control 
unit 107 requests the memory card 300 for a maximum current 
consumption value I max, which represents a maximum amount of 

20 the current consumed by the memory card 300. The control unit 
107 receives the maximum current consumption value Imax from 
the memory card 3 00 via the external IF unit 101. As receiving 
the maximum current consumption value Imax, the control unit 
107 reads out the available supply current value Iok from the 

25 available supply current value storage unit 110, and outputs 
the readout available supply current value Iok to the memory 
card 300 via the external IF unit 101. Subsequently, the control 
unit 107 receives an Ack (Acknowledgement) signal from the 



memory card 300, and ends the initialization. 
[0041] (4-2) Writing Process 

Receiving from the input control unit 112 operation 
directing information that indicates writing data to the memory 
5 card 300 , the control unit 107 generates a write command 
directing the memory card 300 to perform data writing . The write 
command includes a sector number that is a logical address of 
a sector with which the writing begins (hereinafter, referred 
to as the "start sector number") and the number of sectors 
10 required for recording data. A sector is the unit of data 
reading and writing from/into the memory card 300, and has a 
storage area of 512 bytes. 

[0042] Next, the control unit 107 outputs the generated 

write command to the memory card 300 via the external IF unit 
15 101. 

The control unit 107 subsequently receives from the memory 
card 300 a response indicating that data writing is possible. 
Receiving the response, the control unit 107 outputs data 
equivalent to one sector, or 512 bytes, which is obtained from 

20 the beginning of data to be written into the memory card 300. 
In the following description, data of 512 bytes is referred to 
as a data block. Receiving from the memory card 3 00 a response 
indicating that writing one data block is possible, the control 
unit 107 outputs the next data block. In a similar fashion, 

25 the control unit 107 repeats the response reception and data 
block output until all data blocks are output. 
[0043] (4-3) Reading Process 

Receiving from the input control unit 112 operation 



directing information that indicates reading data from the 
memory card 300, the control unit 107 outputs a read command 
directing the memory card 300 to perform data reading. The read 
command includes a sector number that is a logical address of 
5 a sector with which the reading begins (hereinafter, referred 
to as the "start sector number") and the number of sectors to 
be read. 

[0044] The control unit 107 subsequently receives from the 

memory card 3 00 a response indicating that outputting one data 

10 block is possible. Then, the control unit 107 receives from 
the memory card 300 a data block of 512 bytes — corresponding 
to one sector. In a similar fashion, the control unit 107 
repeats the response reception and data block reception until 
the number of received data blocks matches the number of sectors 

15 included in the output read command. 

[0045] Note that control information, such as the maximum 

consumption current value and the available supply current value, 
and various commands are given and received between the PC 100 
and the memory card 3 00 via ATA (AT Attachment) commands. 

20 FIG. 4 shows a frame structure of an ATA command used when 

the PC 100 outputs the available supply current value Iok to 
the memory card 3 00 . In the figure, a name of each field making 
up the frame is shown in the left column, while numbers 0 to 
7, each of which indicates a bit number, are shown in the top 

25 row. A Features field 341 is a field that includes subcommands 
and other extended contents of the command . A Sector Count field 
342 is a field that stores therein the available supply current 
value, the number of sectors and the like. Here, the available 



supply current value of the PC 100 is the value measured at 
Advanced Power Management level. A Sector Number field 343 is 
a field that stores therein the number of sectors when the output 
ATA command is a read/write command, although the field is not 
5 used when the available supply current value Iok is output . "na" 
in the figure indicates that the fields are not in use. 
[0046] A Cylinder Low field 344, a Cylinder High field 345 

and a Device/Head field 346 are fields storing therein 
information that indicates sectors of the reading/writing 
10 destination when the ATA command is a read/write command, 
although these fields are not used in this instance. 

A Command field 347 is a field storing therein a variety 
of commands. Here, "FEh" indicating notice of the available 
supply current value Iok is stored in the field. 
15 [0047] The structure of ATA commands is in the public domain, 
and the detailed explanation is therefore left out here. 

{5) Input Control Unit 112 and Display Control Unit 113 
Connected to the keyboard 150, the input control unit 112 
detects a key operation of the user and outputs to the control 
20 unit 107 operation directing information indicating the 
detected key operation. 

The display control unit 113 generates a screen to be 
presented on the display 140 according to a direction of the 
control unit 107. The display control unit 113 then outputs 
25 the generated screen to the display 140 in synchronization with 
vertical and horizontal sync signals. 
1.3 Memory Card 300 

The memory card 300 comprises, as shown in FIG. 5: an 



external IF unit 3 01; a control unit 302; and flash memories 
310, 311, 312 and 313. The control unit 302 includes a command 
analysis unit 303, a parallel control unit 304, a clock control 
unit 305, memory control units 330, 331, 332 and 333, a control 
5 information storage unit 308 and a buffer memory 309. 

[0048] The control unit 302 includes, concretely speaking, 

a microprocessor , a RAM and a ROM . Computer programs are stored 
in the RAM and ROM. The microprocessor operates according to 
the computer programs , and thereby the control unit 302 fulfills 

10 its function. 

{1) Flash Memories 310, 311, 312 and 313 
The flash memories 310, 311, 312 and 313 individually 
include multiple sectors, each of which has a capacity of 512 
bytes. A memory address is assigned to each sector . Each flash 

15 memory is separately connected to the buff er memory 3 09 , as shown 
in FIG. 5. In addition, the flash memories 310, 311, 312 and 
313 are connected to the memory control units 330, 331, 332 and 
333, respectively. 

[0049] The flash memories 310, 311, 312 and 313 receive a 

20 clock signal from the clock control unit 305 via the memory 
control units 330 , 331, 332 and 333, respectively. With respect 
to each sector, the flash memories 310, 311, 312 and 313 record 
therein various data and output recorded data according to the 
control of the memory control units 330, 331, 332 and 333. 
25 (2) External IF Unit 301 

The external IF unit 301 transmits and receives various 
information between an external apparatus and the control unit 
302. The external IF unit 301 also receives electric power 



supplied from the external apparatus and outputs the received 
power to each circuit constituting the memory card 300. Here, 
the external apparatus means the PC 100 or video camera 200. 
[0 050] Note that the data input and output speeds between 

5 the external IF unit 3 01 and the external apparatus are 
sufficiently fast, as compared with those between the buffer 
memory 309 and the flash memories 310 to 313. 

{3 ) Control Information Storage Unit 308 and Buffer Memory 

309 

10 The control information storage unit 308 is constituted 

with a ROM, and stores therein a write current consumption value 
Iw, a read current consumption value Ir, the number of memories 
N and a control current value a. 

[0051] The write current consumption value Iw is the amount 

15 of current consumed by a pair of a memory control unit and a 
flash memory of the memory card 300 when data is written to the 
single flash memory. The read current consumption value Ir is 
the amount of current consumed by a pair of a memory control 
unit and a flash memory when data is output from the single flash 
20 memory. Here, the sum of the current consumed by the memory 
control units 330 to 333 and flash memories 310 to 313 is 
proportional to the number of flash memories in operation. 
[0052] The number of memories N is the number of flash 

memories provided in the memory card 3 00, and N = 4 here in the 
25 present embodiment. The control current value a is the sum of 
the current consumed by individual circuits other than the flash 
memories and memory control units. 

The buffer memory 309 is constituted with a RAM, and has 
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four areas, each of which stores therein data equivalent to 512 
bytes. The four storage areas respectively correspond to a 
different one of the flash memories 310 to 313. The buffer 
memory 309 temporarily stores therein a variety of data input 
5 and output between the flash memories 310 to 313 and the external 
apparatus . 

[0053] Specifically speaking, the buffer memory 309 

receives a data block of 512 bytes from the external apparatus 
via the external IF unit 301, and stores therein the received 

10 data block. Each time when receiving one data block , the buff er 
memory 3 09 outputs to the parallel control unit 3 04 an OK signal 
indicating that the data block has been properly received. 
According to the control of the memory control units 33 0 to 333, 
the buffer memory 309 outputs the stored data block to the flash 

15 memory 310, 311, 312 or 313. 

[0054] in addition, the buffer memory 309 receives a data 

block from the flash memory 310, 311, 312 or 313, and stores 
therein the received data block on a temporary basis . According 
to a direction of the parallel control unit 304, the buffer 

20 memory 309 then outputs the stored data block to the external 
apparatus via the external IF unit 301. After the output of 
the data block is completed, the buffer memory 3 09 outputs to 
the parallel control unit 304 an OK signal indicating that the 
output has been finished properly. 

25 (4) Clock Control Unit 305 

The clock control unit 305 generates a clock signal at 
predetermined time intervals, and outputs the generated clock 
signal to each unit constituting the memory card 300. 



(5) Command Analysis Unit 303 

The command analysis unit 303 receives a variety of 
commands from an external apparatus connected to the external 
IF unit 301, analyzes each received command, and outputs the 
5 analysis result to the parallel control unit 304. 

(6) Memory Control Units 330, 331, 332 and 333 

The memory control unit 330 receives a clock signal from 
the clock control unit 3 05 and outputs the received clock signal 
to the flash memory 310. 

10 [0055] The memory control unit 330 receives from the 

parallel control unit 304 a write direction indicating data 
writing together with a memory address indicating, within the 
flash memory 310 in which writing takes place, a sector for 
writing a data block thereto. In addition, the memory control 

15 unit 330 receives from the parallel control unit 304 a read 
direction indicating data reading along with a memory address 
indicating, within the flash memory 3 10 in which reading takes 
place, a sector for reading a data block therefrom. 
[0056] Receiving a write direction and a memory address, 

20 the memory control unit 330 writes a data block stored in the 
buffer memory 309 into a sector of the flash memory 3 10, 
corresponding to the received memory address. 

After completing the writing to the flash memory 3 10, the 
memory control unit 330 outputs to the parallel control unit 

25 304 an end signal indicating that writing one data block is 
completed. 

[0057] When receiving a read direction and a memory address 

from the parallel control unit 304, the memory control unit 330 



outputs to the buffer memory 309 a data block stored in a sector 
of the flash memory 310, corresponding to the received memory 
address. After completing the output of the data block, the 
memory control unit 330 outputs to the parallel control unit 
5 304 an end signal indicating that reading one data block is 
completed. 

[0058] The memory control units 331, 332 and 333 implement 

a similar control performed by the memory control unit 33 0 over 
the flash memories 311, 312 and 313, respectively. 

10 (7) Parallel Control Unit 304 

The parallel control unit 304 comprises, as shown in FIG. 
6: a command execution unit 321; a parallel computation unit 
3 2 2; and a memory number computation unit 323. 
[0059] (7-1) Parallel Computation Unit 322 

15 The parallel computation unit 322 is directed by the 

command execution unit 321 to calculate the maximum current 
consumption value Iraax which is a maximum amount of the current 
consumed by the memory card 300. The parallel computation unit 
322 also receives the available supply current value Iok from 

20 the command execution unit 321, and is directed to calculate 
a parallel write count Nw and a parallel read count Nr. The 
parallel write count Nw is the number of flash memories capable 
of performing data writing in parallel within the available 
supply current value, while the parallel read count Nr is the 

25 number of flash memories capable of performing data reading in 
parallel within the available supply current value. 
[0060] Directed to calculate the maximum current 

consumption value I max, the parallel computation unit 322 reads 



out from the control information storage unit 3 08 the write 
current consumption value Iw, the read current consumption value 
Ir, the number of memories N and the control current value a. 
Based on the readout write current consumption value Iw, read 
5 current consumption value Ir, number of memories N and control 
current value a, the parallel computation unit 322 calculates: 

Imax = Max(NxIw, Nxlr)+a (Eq. 1) . 

Here, "Max (A, B)" means a larger one of A and B. The parallel 
computation unit 322 outputs the calculated maximum current 
10 consumption value Imax to the command execution unit 321. 

[0061] Directed to calculate the parallel write count Nw 

and the parallel read count Nr, the parallel computation unit 
322 compares the received available supply current value Iok 
and the calculated maximum current consumption value Imax, 
15 When Iok<Imax, the parallel computation unit 322 then 
calculates : 

Nw = INT{ (Iok-a) /Iw} (Eq. 2); and 

Nr = INT{ (Iok-a) /Ir} (Eq. 3). 

Here, INT (A) indicates the largest integer no larger than A. 
20 At this point, if Nw>N, then the parallel computation unit 322 
sets Nw=N. If Nr >N , Nr=N. 
[0062] If Iok>Imax, Nw = Nr = N. 

Subsequently, the parallel computation unit 322 stores 
therein the calculated parallel write count Nw and parallel read 
25 count Nr, and outputs to the command execution unit 321 a 
computation end signal indicating that the computation is 
properly finished. 

(7-2) Memory Number Computation Unit 323 



The memory number computation unit 323 prestores therein 
the number of flash memories provided in the memory card 300 — N 
= 4. In addition, the memory number computation unit 3 2 3 manages 
correspondence between memory addresses that are actual 
5 addresses of sectors in the flash memories 310 to 313 and sector 
numbers output by the external apparatus. 

[0063] The memory number computation unit 323 receives the 

start sector number and the number of sectors from the command 
execution unit 321, and is directed to calculate 

10 writing-destination memory numbers or reading-destination 
memory numbers . 

Directed to calculate writing-destination memory numbers 
or reading-destination memory numbers, the memory number 
computation unit 323 generates a memory table 324 shown in FIG. 

15 6, and temporarily stores therein the generated memory table 
324 . 

[0064] The memory table 324 comprises one or more memory 

information sets 326, 327.... Each memory information set is 
constituted with a sector number, a memory number and a memory 

20 address. A sector number is a logical address of a sector 
specified by the external apparatus for data writing or reading . 
Each memory number corresponds to a flash memory for data writing 
or reading, and the memory numbers "0", "1", "2" and "3" indicate 
the flash memories 310 , 311, 312 and 313, respectively. A memory 

25 address is a physical address of a sector of a flash memory. 
[0065] Specifically speaking, the memory table 324 is 

generated according to the following computation. 

Directed to calculate writing-destination memory numbers, 
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the memory number computation unit 323 calculates a sector 
number and a memory number according to the following (Eq. 4) 
and (Ep . 5 ) , based on the received start sector number and number 
of sectors: 

5 Sector Number = Start Sector Number + t {Eq. 4) ; and 

Memory Number = (Sector Number) %N (Eq. 5} . 

Here, a variable t is an integer no less than 0 and its 
initial value is 0. 

[0066] The memory number computation unit 323 then 

10 specifies a memory address of a sector for data writing or 
reading, and thus generates a memory information set. Next, 
the memory number computation unit 323 adds one to the variable 
t. In a similar fashion, the memory number computation unit 
323 repeats the calculation of a sector number, calculation 

15 of a memory number, specification of a memory address and 
increment of the variable t until the variable t matches the 
received number of sectors, and thereby generates as many memory 
information sets as the received number of sectors. 

The memory table 324 shown in FIG. 6 is an example of a 

20 memory table generated by the memory number computation unit 
323 in the case where the memory number computation unit 323 
received the start sector number "3" and the number of sectors 
"4". The memory information set 326 shows that a sector 
identified with the sector number "3" is made to correspond with 

25 a sector having a memory address "AAAA" in the flash memory 313 
corresponding to the memory number "3". 

[0067] Next, the memory number computation unit 321 outputs 

a computation end signal indicating that the computation of 



memory numbers is completed. 

(7-3) Command Execution Unit 321 

The command execution unit 321 is, as shown in FIG. 6, 
connected to each circuit constituting the parallel control unit 
5 304 as well as to the memory control units 330 to 333 , and controls 
operations of these individual circuits. 

[0068] The command execution unit 321 receives commands 

analyzed by the command analysis unit 3 03, and performs, 
according to each of the received commands, initialization, a 
10 writing process or a reading process described hereinafter. 
<Initialization> 

Receiving a request for the maximum current consumption 
value Imax via the command analysis unit 303, the command 
execution unit 321 directs the parallel computation unit 322 

15 to calculate the maximum current consumption value Imax. 
Receiving the maximum current value Imax from the parallel 
computation unit 322, the command execution unit 321 outputs 
the received maximum current consumption value Imax to an 
external apparatus via the external IF unit 301. Here, the 

20 external apparatus is the PC 100 or the video camera 200. 

[0069] The command execution unit 321 receives the 

available supply current value Iok from the external apparatus 
via the external IF unit 301 and command analysis unit 303. 
Receiving the available supply current value Iok, the command 

25 execution unit 321 outputs the received available supply current 
value Iok to the parallel computation unit 322, and directs the 
parallel computation unit 322 to calculate the parallel write 
count Nw and the number of parallel read operations Nr. The 



command execution unit 321 next receives a computation end 
signal indicating that the computation is finished properly, 
and outputs an Ack signal to the external apparatus via the 
external IF unit 301. 
5 [0070] <Writing Process> 

Receiving a write command via the command analysis unit 
303, the command execution unit 321 checks whether at least one 
of the four storage areas of the buffer memory 3 09 is free, and 
judges whether one data block can be written thereto. When one 

10 or more storage areas are free, the command execution unit 321 
judges that data writing is possible , and outputs to the external 
apparatus via the external IF unit 301 a response indicating 
that writing one data block is possible. If judging that data 
writing is not possible, the command execution unit 321 waits 

15 ready until any of the storage areas becomes available. 

[0071] After outputting the response, the command 

execution unit 321 performs: (a) data block reception control; 
and (b) data writing control, described below, 
(a) Data Block Reception Control 

20 After the external apparatus has written one data block 

into the buffer memory 3 09, the command execution unit 321 
receives from the buffer memory 309 an OK signal indicating that 
writing one data block is finished. 

[0072] After receiving the OK signal , the command execut ion 

25 unit 321 checks whether there is a free storage area available 
in the buffer memory 3 09 once again and judges whether a data 
block can be written thereto. If data writing is not possible, 
the command execution unit 321 waits ready until data writing 



will be allowed. When data writing becomes possible, the 
command execution unit 321 outputs to the external apparatus 
via the external IF unit 301 a response indicating that writing 
one data block is possible. 
5 [0073] (b) Data Writing Control 

The command execution unit 321 reads the parallel write 
count Nw stored in the parallel computation unit 322. Next, 
the command execution unit 321 outputs the start sector number 
and the number of sectors included in a write command to the 

10 memory number computation unit 323 , and directs the memory- 
number computation unit 323 to calculate writing-destination 
memory numbers. 

The command execution unit 321 receives a computation end 
signal from the memory number computation unit 323 . The command 

15 execution unit 321 subsequently selects Nw pieces of memory 
information sets starting with the first set of the memory table 
324 in the memory number computation unit 323, extracts memory 
numbers and memory addresses from the selected memory 
information sets , and outputs to individual memory control units 

20 corresponding to the extracted memory numbers, an extracted 
memory address and a write direction indicating data writing. 
[0074] Assume a specific example where the start sector 

number is "3", the number of sectors is "4" and the parallel 
write count Nw is "2". The command execution unit 321 extracts 

25 a memory number and a memory address from each of the memory 
information sets 326 and 327. The command execution unit 321 
then outputs a write direction and a memory address "AAAA" to 
the memory control unit 333, which controls the flash memory 



313 corresponding to the memory number "3", while outputting 
a write direction and a memory address "BBBB" to the memory 
control unit 330, which controls the flash memory 310 
corresponding to the memory number "0". 
5 [0075] Next, the command execution unit 321 receives from 

one of the memory control units 333 and 330 an end signal 
indicating that writing one data block is finished. Up to this 
point, the command execution unit 321 has finished directing 
each of the memory control units 333 and 330 to write a data 

10 block to their corresponding flash memories 313 and 310 — namely, 
write operations for only two data blocks, in total, have been 
directed so far . Thus, since having not finished to direct write 
operations for as many data blocks as the number of sectors "4" 
in the received write command, the command execution unit 321 

15 moves on to the next memory information set 328 in the memory 
table 324 and extracts a memory number "1" and a memory address 
"CCCC" therefrom. Then, the command execution unit 321 outputs 
a write direction and the memory address " CCCC" to the memory 
control unit 331, which corresponds to the extracted memory 

20 number "1" . 

[0076] In like fashion, the command execution unit 321 

outputs a write direction and a memory address "DDDD" to the 
memory control unit 332 corresponding to a memory number "2". 

After having directed write operations for four data 
25 blocks, which match the received number of sectors "4", the 
command execution unit 321 finishes the control of data writing 
to the flash memories. 

<Reading Process> 
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Receiving via the command analysis unit 303 a read command 
indicating data reading, the command execution unit 321 
performs: {a) data reading control; and (b) data block output 
control, described below. 
5 [0077] (a) Data Reading Control 

The command execution unit 321 outputs to the memory number 
computation unit 323 the start sector number and the number of 
sectors included in the read command, and directs the memory 
number computation unit 323 to calculate reading-destination 
10 memory numbers. 

The command execution unit 321 next receives a computation 
end signal from the memory number computation unit 323 , and reads 
the parallel read count Nr stored in the parallel computation 
unit 322. 

15 [0078] Then, the command execution unit 321 outputs the 

calculated memory numbers indicating flash memories for data 
reading to corresponding memory control units, in a similar 
procedure described in (b) data writing control of the writing 
process. Note that, in the data reading control, the command 

20 execution unit 321 uses the parallel read count Nr instead of 
the parallel write count Nw, and outputs a read direction 
indicating data reading, instead of a write direction. 

The command execution unit 321 next receives from one of 
the memory control units an end signal indicating that reading 

25 one data block has been finished. Up to this point, if having 
already output directions for reading as many data blocks as 
the number of sectors included in the received read command, 
the command execution unit 321 finishes the data reading 



control . 

[0079] When having not yet output directions for reading 

as many data blocks as the number of sectors, the command 
execution unit 321 outputs a read direction to a memory control 
5 unit corresponding to a memory number included in the next memory 
information set. 

(b) Data Block Output Control 

Receiving a read command, the command execution unit 321 
checks data stored in the buffer memory 309, and judges whether 

10 one data block can be output therefrom. That is, the command 
execution unit 321 checks whether one or more data blocks have 
been transferred to the buffer memory 309 from flash memories. 
[0080] if determining that the output is not possible, the 

command execution unit 321 waits ready until transferring one 

15 data block from one of the flash memories to the buffer memory 
309 is completed. 

If determining that the output is possible, the command 
execution unit 321 outputs to the external apparatus via the 
external IF unit 3 01 a response indicating that outputting a 

20 data block is possible. 

Subsequently, the command execution unit 321 directs the 
buffer memory 309 to output one data block. The command 
execution unit 321 then receives from the buffer memory 309 an 
OK signal indicating that the output of the data block is 

25 finished properly. Receiving the OK signal, the command 
execution unit 321 checks data stored in the buffer memory 309 
once again, and judges whether outputting another data block 
is possible. 



[0081] From then on until outputting as many data blocks 

as the number of sectors included in the received read command, 
the command execution unit 321 repeats: making a judgement of 
whether outputting one data block is possible; outputting a 
5 response; and outputting one data block. 

1.4 Operations of Memory Card 300 and PC 100 
Here is explained a case in which the memory card 300 is 
attached to the PC 100, although the memory card 300 can also 
be attached to the video camera 200. 
10 [0082] (1) Opera tions Taken When Memory Card 300 is Attached 

Operations of the PC 100 and memory card 300 right after 
the memory card 300 is attached to the PC 100 are described next 
with the aid of a flowchart of FIG. 7. 

The PC 100 detects via the external IF unit 101 the memory 
15 card 300 being placed therein (Step S101) . Next, the PC 100 
requests the memory card 3 00 for the maximum current consumption 
value Imax via the external IF unit 101 (Step S102) . 
[0083] The memory card 300 receives the request for the 

maximum current consumption value Imax from the PC 10 0 via the 
20 external IF unit 301. Receiving the request for the maximum 
current consumption value Imax, the memory card 300 reads out 
from the control information storage unit 3 08 the write current 
consumption value Iw, the read current consumption value Ir, 
the number of memories N and the control current value a (Step 
25 S104) . The memory card 300 next calculates the maximum current 
consumption value Imax based on the readout write current 
consumption value Iw, read current consumption value Ir, number 
of memories N and control current value a (Step S106) , and 



outputs the calculated maximum current consumption value Imax 
to the PC 100 (Step S107) . 

[0084] The PC 100 receives the maximum current consumption 

value Imax from the memory card 300. Receiving the maximum 
5 current consumption value Imax, the PC 10 0 reads out the 
available supply current value Iok from the available supply 
current value storage unit 110 (Step S108), and outputs the 
readout available supply current value Iok to the memory card 
300 (Step S109) . 

10 The memory card 300 receives the available supply current 

value Iok from the PC 100 via the external IF unit 301, and 
compares the received available supply current value Iok with 
the calculated maximum current consumption value Imax (Step 
Sill) . If Iok^lmax (Step Sill: YES) , then the memory card 300 

15 sets the parallel write count Nw = the parallel read count Nr 
= the number of memories N (Step S112) . 

[0085] If Iok<Imax {Step Sill: NO), the memory card 300 

calculates Nw= INT { ( Iok- a) / Iw} (Step S113), calculates 
Nr=INT{ (Iok-a) /Ir} (Step S114), and stores therein the 

20 calculated parallel write count Nw and parallel read count Nr. 
Subsequently, the memory card 300 outputs an Ack signal to the 
PC 100 (Step S116) . 

(2) Operations for Writing to Memory Card 300 
Operations for writing data to the memory card 300 are 

25 described next with the aid of a flowchart of FIG. 8. The 
description here is given based on a specific case where the 
parallel write count Nw is "2", the start sector number is "3" 
and the number of sectors is "4" . 



[0086] The PC 100 receives a key operation of the user (Step 

S121) . When the received key operation is one indicating data 
writing to the memory card 300, the PC 100 generates a write 
command including the start sector number "3" and the number 
5 of sectors "4" (Step 3123), and outputs the generated write 
command to the memory card 300 (Step S124) . 

The memory card 3 00 receives the write command from the 
PC 100, checks free space of the buffer memory 309, and judges 
whether writing one data block is possible (Step S126) . If 
10 determining that the writing is not possible (Step S126: NO) , 
the memory card 300 waits ready until free space becomes 
available in the buffer memory 309 for writing one data block. 
[0087] If determining that the writing is possible (Step 

S126: YES) , the memory card 300 generates a response indicating 
15 that the data writing is possible (Step S128) and outputs the 
generated response to the PC 100 (Step S129) . 

The PC 100 receives the response from the memory card 3 00 
(Step S129) . Receiving the response, the PC 100 reads one data 
block out of the data to be output (Step S131) and outputs the 
20 read data block to the memory card 300 (Step S132) . 

[0088] The memory card 300 receives the data block from the 

PC 100, and writes the received data block to the buffer memory 
309 (Step S133) . When having finished to write the data block 
to the buffer memory 3 09 , the memory card 3 00 checks free space 
25 of the buffer memory 309 once again, and judges whether writing 
thereto one data block is possible (Step S134) . If determining 
that the writing is not possible (Step S134: NO), the memory 
card 300 waits ready until free space becomes available in the 



buffer memory 309 for writing one data block. 
[0089] If determining that the writing is possible {Step 

S134: YES) , the memory card 300 outputs to the PC 100 a response 
indicating that writing one data block is possible . In a similar 
5 fashion, each time when receiving a data block from the PC 100, 
the memory card 300 repeats Steps S133 to S136. 

The PC 100 receives the response from the memory card 300 
(Step S136) . Up to this point, if the PC has not yet output 
all data blocks making up the data which will be written to the 
10 memory card 300 (Step S134: NO), the process returns to Step 
S129 and the next data block is output. 

[0090] In addition, the memory card 3 0 0 performs Steps S14 1 

to S147 — data transfer from the buffer memory 309 to each flash 
memory, in parallel with Step S133 to S136. 

15 First, the memory card 3 00 calculates the memory numbers 

"3" , "0" , "1" and "2" each indicating a flash memory for writing 
data blocks based on the start sector number "3" and the number 
of sectors "4" included in the received write command, and 
generates the memory table 324 (Step S141) . Since Nw = 2, the 

20 memory card 3 00 outputs a write direction to each of the memory 
control units 33 3 and 33 0 corresponding to the memory numbers 
"3" and "0", respectively, and starts transferring data blocks 
from the buffer memory 3 09 to the flash memories 313 and 310 
(Step S142) . 

25 [0091] The data block transfer to either one of the flash 

memories finishes (Step S143) . At this point, the memory card 
300 has not yet finished to direct memory control units to 
transfer as many data blocks as the received number of sectors 



"4" (Step S144: NO) . Therefore, the memory card 300 reads out 
the next memory number and memory address — specifically 
speaking, the memory number "1" and memory address "CCCC" — from 
the memory table 324. Then, the memory card 300 outputs the 
5 memory address "CCCC" and a write direction to the memory control 
unit 331 which corresponds to the readout memory number "1", 
and the memory control unit 331 starts transferring a data block 
to the flash memory 311 (Step S146) . 

[0092] The memory card 300 repeats Steps S143 to S146, and 

10 starts transferring a data block to the flash memory 3 12 
indicated by the memory number "2" . 

Next, in Step S144, the memory card 300 determines to have 
finished directing the memory control units to transfer a total 
of four data blocks to the flash memories (Step S144 : YES) . When 

15 transfer of all these data blocks to the flash memories is 
completed (Step S147) , the write operations are finished. 
[0093] (3) Time Chart of Write Operations 

Next are described timings of giving and receiving 
commands and data between the memory card 300 and the PC 10 0 

20 and operation timings of the flash memories 310 to 3 13 when data 
is written to the memory card 300, with the aid of a time chart 
shown in FIG. 10. Assume here that the parallel write count 
Nw=2, and all four storage areas of the buffer memory 309 are 
free at the time of the reception of a write command. 

25 [0094] In FIG. 10, a command and data blocks that the memory 

card 300 receives from the PC 100 and responses output from the 
memory card 300 to the PC 100 are depicted along the time course 
of the write operations, and the horizontal axis represents time 



In addition, the figure shows operating conditions of the flash 
memories 310 to 313 at each instant of time. 

The memory card 300 receives a write command AO from the 
PC 100. The write command AO includes the start sector number 
5 "3" and the number of sectors "4". 

[0095] The memory card 300 checks free space of the buffer 

memory 309, and outputs to the PC 100 a response 131 indicating 
that writing a data block of 512 bytes thereto is possible. 

Receiving the response 131, the PC 100 outputs a data block 
10 Al to the memory card 300. 

[0096] At the same time, the memory card 300 starts 

transferring the data block Al from the buffer memory 309 to 
the flash memory 313 . When the output of the data block Al from 
the PC 100 to the memory card 300 is finished, the memory card 
15 300 checks free space of the buffer memory 309 once again, and 
outputs to PC 100 a response 132 indicating that writing a data 
block thereto is possible. 

[0097] Receiving the response 132, the PC 100 outputs a data 

block A2 to the memory card 300. 
20 At the same time, the memory card 300 starts transferring 

the data block A2 from the buffer memory 309 to the flash memory 
310 . 

When the output of the data block A2 from the PC 100 to 
the memory card 300 is finished, the memory card 300 checks free 
25 space of the buffer memory 309 once again, and outputs to PC 
100 a response 133 indicating that writing a data block thereto 
is possible. 

[0098] In like fashion, receiving the response 133, the PC 



100 outputs a data block A3 to the memory card 3 00 . Here, since 
the parallel write count Nw is two and thus the flash memories 
313 and 310 are operating, the rest of the flash memories do 
not operate until the transfer to either of the flash memories 
5 313 and 310 is finished. 

The output of the data block A3 from the PC 100 to the memory 
card 300 is finished. The memory card 300 checks free space 
of the buffer memory 309 once again, and outputs to the PC 100 
a response 134 indicating that writing a data block thereto is 
10 possible. 

[0099] Receiving the response 134, the PC 100 outputs the 

data block A4 to the memory card 300. 

The data blocks Al to A4 are now stored in the buffer memory 
309, and no new data block can be written thereto. At the point 
15 when the writing of the data block Al is finished in the flash 
memory 313, which is the first flash memory having started 
receiving the data block transfer, writing a new data block to 
the buffer memory 3 09 becomes possible. The memory card 300 
then outputs to the PC 100 a response 135 indicating that writing 
20 a data block thereto is possible. 

[0100] At the same time, the memory card 3 00 starts 

transferring the data block A3 from the buffer memory 309 to 
the flash memory 311. When the transfer of the data block A2 
to the flash memory 310 is finished, the memory card 3 00 
25 subsequently starts transferring the data block A4 from the 
buffer memory 309 to the flash memory 312. 

1.5 Summary and Advantageous Effects 

As has been described above, the memory card 300 obtains, 



when connected to an external apparatus, the available supply 
current value of the external apparatus, and calculates the 
parallel write count Nw and the parallel read count Nr in order 
to keep the current consumption value of the memory card 300 
5 to no more than the obtained available supply current value. 
[0101] When receiving a write command from the external 

apparatus, the memory card 300 performs a writing process by 
operating Nw pieces of flash memories in parallel. When 
receiving a read command from the external apparatus, the memory 

10 card 300 performs a reading process by operating Nr pieces of 
flash memories in parallel. 

Advantageous effects of the present invention are 
illustrated next, using specific numerical values. 

Assume that the write current consumption value Iw=10 0 mA; 

15 the read current consumption value Ir=50 mA; the number of 
memories N=4 ,* the control current value a=100 mA; and the writing 
and reading speed of the respective flash memories 310 to 313 
is 4 MB/s. 

[0102] Receiving the available supply current value 

20 Iok=350 mA from the PC 100, the memory card 300 calculates Nw 
and Nr using (Eq. 2) and (Eq. 3) : 

Nw = INT{ (350-100) /100 } = 2; and 
Nr = INT{ (350-100) /50 } = 5. 
Since Nr > N here, Nr = N = 4 . 
25 [0103] In the case with the above assumed numerical values, 

the current consumption values of the memory card 300 during 
the writing operations and during the reading operations are 
300 mA and 350 mA, respectively, both of which are no greater 



than the available supply current value, 350 raA. 

The writing speed of the memory card 300 in this case is 
8 MB/s since two flash memories can be operated in parallel, 
and thus a two- fold faster writing speed can be achieved as 
5 compared to the case where no parallel operations take place. 
On the other hand, the reading speed is 16 MB/s since four flash 
memories can be operated in parallel. As a result, four times 
faster reading is accomplished when compared to the case where 
no parallel operations are performed. 
10 [0104} Herewith, a large increase in both reading and 

writing speeds can be efficiently realized within the power 
supply capacity of the PC 100. 

2 . EMBODIMENT 2 

Next is described a memory card 600 of Embodiment 2 

15 according to the present invention. 

The memory card 600 is set in the PC 100 or the video camera 
200, as in the case of the memory card 3 00 of Embodiment 1 . Since 
the structure and operations of the PC 100 and video camera 200 
are the same as in the case of Embodiment 1, their descriptions 

20 are omitted here . 

[0105] The memory card 600 is equipped with four flash 

memories. The memory card 600 receives the available supply 
current value from an external apparatus — specifically speaking 
the PC 100 or the video camera 200, and calculates the operating 

25 frequency of the flash memories in order to keep the current 
consumption value of the memory card 60 0 to no more than the 
received available supply current value. Receiving a command 
from the external apparatus, the memory card 60 0 operates the 



flash memories at the calculated operating frequency. 
2.1 Memory Card 600 

The memory card 600 comprises, as shown in FIG. 11: an 
external IF unit 601; a control unit 602; flash memories 610, 
5 611, 612 and 613. 

[0106] The control unit 602 includes: a command analysis 

unit 603 ; a parallel control unit 604; a clock control unit 605; 
memory control units 63 0 , 631, 632 and 633 ; a control information 
storage unit 608; and a buffer memory 609. 
10 The control unit 602 is made up of, concretely speaking, 

a microprocessor, a RAM and a ROM. Computer programs are stored 
in the RAM and ROM. The microprocessor operates according to 
the computer programs , and thereby the control unit 602 fulfills 
its function. 

15 [0107] The structures and operations of the external IF unit 

601, command analysis unit 603, memory control units 630, 631, 
632 and 633, buffer memory 609, and flash memories 610, 611, 
612 and 613 are the same as those of the counterparts in 
Embodiment 1 — i.e. the external IF unit 3 01; the command 

20 analysis unit 303; the memory control units 330, 331, 332 and 
333; the buffer memory 309; and the flash memories 310, 311, 
312 and 313. Accordingly, their explanations are left out here , 
and the following description focuses only on features of the 
present embodiment, the parallel control unit 604, the clock 

25 control unit 605 and the control information storage unit 608. 
[0108] (1) Control Information Storage Unit 608 

The control information storage unit 608 is constituted 
with a ROM , and stores therein a write current consumption value 



Iw, a maximum read current consumption value Irmax, the number 
of memories N , a maximum frequency fmax and a control current 
value a, as shown in FIG. 11. 

The write current consumption value Iw, the number of 
5 memories N and control current value a are the same as those 
in Embodiment 1 . 

[0109] The maximum frequency fmax is an operating frequency 

of each flash memory in the memory card 600 when the flash 
memories operate data reading at the maximum reading speed. 

10 The maximum read current consumption value Irmax is the 

amount of the current consumed by one flash memory and its 
corresponding memory control unit when the flash memory operates 
data reading at the maximum reading speed, i.e. at the maximum 
frequency fmax. 

15 [0110] (2) Clock Control Unit 605 

The clock control unit 605 is equipped with a PLL (Phase 
Lock Loop) . The clock control unit 605 generates a clock signal 
at predetermined time intervals , and outputs the generated clock 
signal to each unit constituting the memory card 600. The 

20 frequency of the clock signal that the clock control unit 605 
supplies to the flash memories 610 to 613 via the memory control 
units 630 to 633 is generally the maximum frequency fmax. When 
the frequency of the clock signal is the maximum frequency fmax, 
the operating frequencies of the memory control units 63 0 to 

25 633 and flash memories 610 to 613 are also fmax. 

[0111] The clock control unit 605 receives from the parallel 

control unit 604 a frequency change direction and a reading 
frequency fr. The reading frequency fr is an upper limit of 



the operating frequencies of the flash memories 610 to 613 for 
keeping the amount of the current consumed toy the memory card 
600 to no more than the available supply current value Iok when 
the flash memories 610 to 613 are operating data reading in 
5 parallel. 

Receiving a frequency change direction, the clock control 
unit 605 changes the frequency of the clock signal to be supplied 
to the memory control units 630 to 633 into the received reading 
frequency fr, using the PLL. 

10 [0112] When receiving a change ending direction from the 

parallel control unit 604, the clock control unit 605 changes 
the frequency of the clock signal to be supplied to the flash 
memories 610 to 613 back to the normal, maximum frequency fmax 
from the reading frequency fr. 

15 (3) Parallel Control Unit 604 

The parallel control unit 604 comprises, as shown in FIG. 
12: a command execution unit 621; a parallel computation unit 
622; and a memory number computation unit 623. 
[0113] The memory number computation unit 623 is the same 

20 as the counterpart of Embodiment 1, and therefore the following 
describes only features of the present embodiment, the command 
execution unit 621 and the parallel computation unit 622. 
(3-1) Parallel Computation Unit 622 

The parallel computation unit 622 is directed by the 
25 command execution unit 62 1 to calculate the maximum current 
consumption value Imax . Additionally, the parallel 

computation unit 622 receives the available supply current value 
Iok from the command execution unit 621, and is directed to 



calculate the parallel write count Nw and the reading frequency 
fr . 

[0114] Directed to calculate the maximum current 

consumption value Iraax, the parallel computation unit 622 reads 
5 out from the control information storage unit 608 the write 
current consumption value Iw, the maximum read current 
consumption value Irmax, the number of memories N and the control 
current value a. The parallel computation unit 622 calculates 
the maximum current consumption value Imax based on the readout 

10 write current consumption value Iw, read current consumption 
value Ir, number of memories N and control current value a: 

Imax = Max(NxIw, Nxlrmax) +a (Eq. 6) . 

The parallel computation unit 622 outputs the calculated maximum 
current consumption value Imax to the command execution unit 

15 621. 

[0115] Directed to calculate the parallel write count Nw 

and the reading frequency fr, the parallel computation unit 622 
reads the maximum frequency fmax from the control information 
storage unit 608. The parallel computation unit 622 then 

20 compares the received available supply current value iok and 
the calculated maximum current value Imax, If Iok<Imax, the 
parallel computation unit 622 calculates: 

Nw = INT{ (Iok-a) /Iw} {Eq. 2); and 

fr = fmaxx (Iok-a) /N/Irmax (Eq. 7) . 

25 Here, if Nw>N, then the parallel computation unit 622 sets Nw=N, 
and if fr>fmax, then the parallel computation unit 622 sets 
f r=f max . 

[0116] If Iok>Imax, the computation unit 622 sets Nw=N and 



f r=fmax . 

Next , the parallel computation unit 622 stores therein the 
calculated parallel write count Nw and reading frequency fr, 
and outputs to the command execution unit 621 a computation end 
5 signal indicating that the computation is properly finished. 
(3-2) Command Execution Unit 621 

The command execution unit 621 prestores therein the 
number of flash memories provided in the memory card 600 — N=4 . 
[0117] The command execution unit 621 receives commands 

10 analyzed by the command analysis unit 603, and performs, 
according to each of the received commands, initialization to 
be hereinafter described, a writing process or a reading process 
The writing process is the same as in Embodiment 1, and therefore 
the description is omitted here. 

15 <Initialization> 

Requested for the maximum current consumption value Imax 
via the command analysis unit 603, the command execution unit 
621 directs the parallel computation unit 622 to calculate the 
maximum current consumption value Imax. Receiving the maximum 

20 current value Imax from the parallel computation unit 622, the 
command execution unit 621 outputs the received maximum current 
consumption value Imax to an external apparatus via the external 
IF unit 601. Here, the external apparatus is the PC 100 or the 
video camera 200. 

25 [0118] The command execution unit 621 receives the 

available supply current value Iok from the external apparatus 
via the external IF unit 601 and command analysis unit 603. 
Receiving the available supply current value Iok, the command 



execution unit 621 outputs the received available supply current 
value Iok to the parallel computation unit 622, and directs the 
parallel computation unit 622 to calculate the parallel write 
count Nw and the reading frequency fr. 
5 The command execution unit 621 receives from the parallel 

computation unit 622 a computation end signal indicating that 
the computation is properly finished. Subsequently, the 
command execution unit 621 outputs an Ack signal to the external 
apparatus via the external IF unit 601. 

10 [0119] <Reading Process> 

The command execution unit 621 receives a read command 
indicating data reading via the command analysis unit 603. The 
read command includes: a start sector number that is a logical 
address of a sector with which the reading begins ; and the number 

15 of sectors to be read. Receiving a read command, the command 
execution unit 621 performs: (a) read control; and (b) data 
block output control, described below. 
[0120] (a) .Read Control 

The command execution unit 621 outputs to the memory number 

20 computation unit 623 the start sector number "5" and the number 
of sectors "4" included in the read command, and directs the 
memory number computation unit 623 to calculate 
reading- destination memory numbers. Next, the command 
execution unit 621 reads out the reading frequency fr from the 

25 parallel computation unit 622, and outputs the readout reading 
frequency fr and a frequency change direction to the clock 
control unit 605. 

[0121] The command execution unit 621 then extracts memory 



numbers and memory addresses from N pieces of memory information 
sets in the memory table stored in the memory number computation 
unit 623, and outputs an extracted memory address and a read 
direction indicating data reading to each of the memory control 
5 units controlling flash memories identified with the extracted 
memory numbers. 

Then, the command execution unit 621 receives from one of 
the memory control units an end signal indicating that the 
reading has been finished. Up to this point, if having not yet 

10 output to the memory control units 630 to 633 directions for 
reading as many data blocks as the number of sectors included 
in the received read command, the command execution unit 621 
extracts the next memory number and memory address from the 
memory table, and outputs a read direction to a memory control 

15 unit corresponding to the extracted memory number. The command 
execution unit 621 repeats the extraction of a memory number 
and a memory address and the output of a read direction to a 
memory control unit until having output read directions for 
reading as many data blocks as the number of sectors. 

20 [0122] Subsequently, the command execution unit 621 

receives end signals from all memory control units to which the 
read directions have been output, and determines that the data 
reading from each flash memory has been finished. When 
determining that the data reading from the individual flash 

25 memories has been finished, the command execution unit 621 
outputs a change ending direction to the clock control unit 605. 
(b) Data Block Output Control 

Receiving a read command, the command execution unit 621 
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checks data stored in the buffer memory 609, and judges whether 
one data block can be output therefrom. That is, the command 
execution unit 621 checks whether one or more data blocks have 
been transferred to the buffer memory 609 from flash memories. 
5 [0123] if determining that the output is not possible, the 

command execution unit 621 waits ready until transferring one 
data block from one of the flash memories to the buffer memory 
609 is completed. 

If determining that the output is possible, the command 

10 execution unit 621 outputs to the external apparatus via the 
external IF unit 601 a response indicating that outputting a 
data block is possible. 

Subsequently, the command execution unit 621 directs the 
buffer memory 609 to output one data block. 

15 [0124] Until outputting to the external apparatus as many 

data block as the number of sectors included in the received 
read command, the command execution unit 621 repeats, in the 
same manner: making a judgement of whether outputting one data 
block is possible ; outputt inga response ; and outputting one data 

20 block. 

2.2 Operations of Memory Card 600 and PC 100 

Here is explained a case in which the memory card 600 is 

attached to the PC 100, although the memory card 600 can also 

be attached to the video camera 200, 
25 [0125] (1) Operations Taken When Memory Card 600 is Attached 

Operations of the initialization when the memory card 600 

is attached to the PC 100 are described next with the aid of 

a flowchart of FIG. 13. 



The PC 100 detects via the external IF unit 101 the memory- 
card 600 being placed therein, and implements a configuration 
process (Step S201) . Next, the PC 100 requests the memory card 
600 for the maximum current consumption value Imax (Step S202) . 
5 [0126] The memory card 600 receives the request for the 

maximum current consumption value Imax from the PC 100. 
Receiving the request for the maximum current consumption value 
Imax, the memory card 600 reads out from the control information 
storage unit 608 the write current consumption value Iw, the 

10 maximum read current consumption value Irmax, the number of 
memories N and the control current value a (Step S203) . The 
memory card 600 next calculates the maximum current consumption 
value Imax using the readout write current consumption value 
Iw, maximum read current consumption value Irmax, number of 

15 memories N and control current value a (Step S204) , and outputs 
the calculated maximum current consumption value Imax to the 
PC 100 (Step S207) . 

[0127] The PC 100 receives the maximum current consumption 

value Imax from the memory card 600, and reads the available 

20 supply current value Iok (Step S209) . The PC 100 outputs the 
read available supply current value Iok to the memory card 600 
via the external IF unit 101 (Step S211) . 

The memory card 600 receives the available supply current 
value Iok from the PC 100, and reads the maximum reading 

25 frequency Emax (Step S212) . 

[0128] Then, the memory card 600 compares the received Iok 

and the calculated maximum current consumption value Imax (Step 
S213 ) . If Iok>Imax (Step S213 : YES) , the memory card 600 assigns 



the number of memories N to the parallel write count Nw and the 
maximum reading frequency fmax to the reading frequency f r (Step 
S214) . 

If Iok<Imax (Step S213 : NO) , the memory card 600 calculates 
5 the parallel write count Nw according to (Eq. 2) (Step S217) . 
Here, if Nw>N, then the memory card 600 sets Nw=N. The memory 
card 600 subsequently calculates the reading frequency fr using 
(Eq. 7) (Step S218) . If fr>fmax, the memory card 600 sets 
f r=f max . 

10 [0129] Then, the memory card 600 outputs to the PC 100 an 

Ack signal indicating that the initialization is finished 
properly (Step S219) . 

(2) Operations for Reading from Memory Card 600 
Operations of the memory card 600 and PC 100 when data is 
15 read from the memory card 600 are described next, with the aid 
of a flowchart shown in FIG. 14. 

[0130] The description here is given based on a specific 

case where the start sector number is w 5" and the number of 
sectors is "4" . 

20 The PC 10 0 receives a key operation of the user ( Step S2 41) . 

When the received key operation one indicating data reading from 
the memory card 600, the PC 100 generates a read command 
including the start sector number "5" and the number of sectors 
"4" (Step S243) , and outputs the generated read command to the 

25 memory card 600 via the external IF unit 101 (Step S244). 

[0131] If the received key operation indicates a process 

other than data reading, the PC 100 performs the process (Step 
S242) . 
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Receiving the read command from the PC 100 , the memory card 
600 calculates the memory numbers "1", "2", "3" and "0" each 
indicating a flash memory for data reading, based on the start 
sector number "5" and the number of sectors "4" included in the 
5 received read command, and generates a memory table (Step S249) . 
[0132] Next, the memory card 600 changes the clock frequency 

which will be output to the memory control units 63 0 to 633 into 
the reading frequency fr (Step S251) . 

The memory card 600 extracts the memory numbers and memory 

10 addresses from N ( = 4) pieces of memory information sets in the 
memory table, and starts transferring a data block to the buffer 
memory 609 from each of the flash memories corresponding to the 
extracted memory numbers "1", "2", "3" and "0" (Step S252). 
10133] When one of the flash memories finishes the data 

15 block transfer (Step S253), if the memory card 600 has not yet 
finished to direct the memory control units to transfer a total 
of four data blocks matching the received number of sectors "4" 
(Step S254 : NO) , then the memory card 600 directs an appropriate 
memory control unit to read the next data block based on the 

20 memory table (Step S256) . 

When the memory card 600 has directed the memory control 
units to output four data blocks in total (Step S254: YES ) and 
then the read operations in all flash memories have been 
completed (Step S257) , the memory card 600 changes the clock 

25 frequency back (Step S258) . 

[0134] The memory card 600 performs the processing of Steps 

S261 to S264 in parallel with Steps S252 to S258, and outputs 
data blocks from the buffer memory 609 to the external apparatus . 



First, the memory card 600 judges whether one or more data 
blocks are present in the buffer memory 609 {Step S261) . If 
there is no data block {Step S261: NO) , the memory card 600 waits 
ready until transferring one data block from any of the flash 
5 memories to the buffer memory 609 is completed. 

[0135] If at least one data block is present (Step S261: 

YES) , the memory card 600 outputs to the PC 100 a response 
indicating that outputting one data block is possible (Step 

5262) . Subsequently, the memory card 600 outputs one data block 
10 to the PC 100 from the buffer memory 609 (Step S263) . When the 

output is finished, the memory card 600 repeats Steps S261 to 
S264 until outputting to the PC 100 a total of four data blocks 
which matches the number of sectors "4" included in the received 
read command. 

15 [013 6] The PC 100 receives a response from the memory card 

600 (Step S262), and subsequently receives a data block (Step 

5263) . Until received four data blocks (Step S266: YES), the 
PC 100 repeats reception of a response and a data block. 

(3) Time Chart of Read operations 

20 Next are described timings of giving and receiving 

commands and data between the memory card 600 and the PC 100 
and read operation timings of the flash memories 610 to 613 in 
the memory card 600 when data is read from the memory card 600, 
with the aid of a time chart shown in FIG. 15. 

25 [013 7] In FIG. 15, a command that the memory card 600 

receives from the PC 100 and data blocks output from the memory 
card 600 to the PC 100 are depicted along the time course of 
the read operations, and the horizontal axis represents time. 



In addition, the figure shows operation conditions of the flash 
memories 610 to 613 at each instant of time. 

The memory card 600 receives a read command BO from the 
PC 100. The read command B0 includes the start sector number 
5 "5" and the number of sectors "4" . 

[0138] The memory card 600 calculates the memory numbers 

"1", "2", "3" and "0" based on the start sector number "5" and 
the number of sectors "4" . The memory card 600 reads out data 
blocks from the flash memories 610 to 613 each corresponding 

10 to the calculated memory numbers : a data block Bl from the flash 
memory 611; a data block B2 from the flash memory 612; a data 
block B3 from the flash memory 613; and a data block B4 from 
the flash memory 610. The memory card 600 then transfers each 
of the readout data blocks to the buffer memory 609. When 

15 finishing the transfer of the data block from the flash memory 
611, the memory card 600 outputs to the PC 100 a response 141 
indicating that outputting one data block is possible. 
Subsequently, the memory card 600 outputs the data block Bl from 
the buffer memory 609 to the PC 100. 

20 [0139] The reading speeds of the four flash memories are 

substantially the same, and therefore the transfer of the data 
blocks from the individual flash memories to the buffer memory 
609 finishes at almost the same time. 

At the time when the output of the data block Bl is finished, 

25 the data blocks B2 to B4 are still in the buffer memory 609. 
Accordingly, the memory card 600 outputs a response 142 
indicating that outputting one data block is possible, and 
outputs the data block B2 . When the output of the data block 



B2 is finished, the memory card 600 performs the output of a 
response 143 and then the data block B3 , and subsequently the 
output of a response 144 and then the data block B4 in a similar 
fashion . 

5 2.3 Summary and Advantageous Effects 

As has been described above, the memory card 600 of 
Embodiment 2 obtains the available supply current value Iok from 
an external apparatus, and calculates the parallel write count 
Nw and the reading frequency fr in order to keep the current 

10 consumption value of the memory card 600 to no more than the 
obtained available supply current value Iok. 
[0140] When receiving a write command from the external 

apparatus, the memory card 600 performs a data writing process 
by operating Nw pieces of flash memories in parallel. 

15 When receiving a read command, the memory card 600 changes 

the frequency of the clock signal to be supplied to the flash 
memories 610 to 613 into the calculated reading frequency fr, 
and performs a data reading process by operating the four flash 
memories 610 to 613 in parallel. 

20 [0141] Advantageous effects of the present embodiment are 

described next , using specif ic numerical values . Since effects 
for the writing process are the same as in Embodiment 1, only 
effects for the reading process are described here. 

Assume that the write current consumption value Iw=120 mA; 

25 the maximum read current consumption value Irmax=100 mA; the 
maximum f requency=l 0 0 MHz ; the number of memories N=4; the 
control current value a=100 mA; and the reading speed of each 
of the flash memories 610 to 613 is up to 10 MB/s. 



[0142] The maximum current consumption value in this case 

is calculated using (Eq. 6) : 

Imax = Max(4xl20, 4xl00)+100 = 580 mA. 
Suppose the available supply current value Iok of the PC 100 
5 is 400 mA, then Iok<Imax. Accordingly, the memory card 600 
calculates the reading frequency fr using {Eq. 7) : 

fr = 100X (400-100} /4/100 = 75 MHz. 
[0143] The current consumption value of the flash memories 

for read operations is proportional to the operating frequency. 
10 Therefore, in the case where the read operations are performed 
by four flash memories at an operating frequency of 75 MHz, the 
amount of current consumed by the memory card 60 0 is: 
Irmax x (fr/fmax) x N + a 

= 100 X (75/100) x 4 + 100 
15 = 400 mA. 

Thus, the current consumption value for operating the four flash 
memories 610 to 613 in parallel at the operating frequency 75 
MHz is kept within the available supply current value of the 
PC 100, 400 mA. 

20 [0144] Since the reading speed of the flash memories is 

proportional to the operating frequency, the reading speed of 
the memory card 600 when the operating frequency is 75 MHz is: 
10 x (75/100) x 4 = 30 MB/s . As a result, by reducing the 
operating frequency of the flash memories to 75 MHz and operating 

25 the four flash memories 610 to 613 in parallel, three times 
faster reading is accomplished when compared to the case where 
the reading process is performed at the maximum frequency with 
no parallel operations. 



[0145] Thus, the reading process can be speeded up to the 

maximum extent possible within the power supply capacity of the 
PC 100. 

Note that high voltage is applied to the flash memories, 
5 which subsequently accumulate electrical charge and thereby 
store data therein. Therefore, the consumption current during 
the write operations is proportional to the voltage application 
time, and the power-saving effect due to a change in the 
frequency cannot be expected. For this reason, the present 
10 embodiment has adopted a structure in which the frequency is 
changed only for the read operations. 
3 . EMBODIMENT 3 

In Embodiments 1 and 2, the present invention is 
illustrated as being a memory card having multiple flash 

15 memories therein. However, a memory card drive 700 shown in 
FIG. 16 is also within the scope of the present invention. 
[0146] The memory card drive 700 is equipped with four 

memory card slots, and used while four memory cards 810, 811, 
812 and 813 being placed therein. The memory card drive 700 

20 is connected to the PC 100 or the video camera 200. 

Like the memory card 300 of Embodiment 1, the memory card 
drive 700 calculates the number of memory cards allowed to 
operate in parallel within the electric power that the PC 100 
or video camera 200 is able to supply, and operates the 

25 calculated pieces of memory cards in parallel. 

[0147] Since the PC 100 and the video camera 200 are the 

same as those in Embodiment 1, their descriptions are left out 
here . 
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3.1 Memory Cards 810, 811, 812 and 813 

Each of the memory cards 810, 811, 812 and 813 includes 
a control unit, a RAM and a nonvolatile memory. According to 
the control of the memory card drive 700, the memory cards 810 
5 to 813 store therein a variety of information, and output the 
stored information. 

3.2 Memory Card Drive 700 

The memory card drive 700 comprises, as shown in FIG. 17: 
an external IF unit 701; a control unit 702; and card IF units 

10 710, 711, 712 and 713. 

[0148] The control unit 702 includes: a command analysis 

unit 703 ; a parallel control unit 704 ; memory control units 730 , 
731, 732 and 733 ; a clock control unit 705 ; a control information 
storage unit 708; and a buffer memory 709. 

15 The control unit 702 includes, concretely speaking, a 

microprocessor, a RAM and a ROM. Computer programs are stored 
in the RAM and ROM. The microprocessor operates according to 
the computer programs, and thereby the control unit 702 fulfills 
its function. 

20 [0149] Next is described each unit constituting the memory 

card drive 700. The structures and operations of the command 
analysis unit 703, clock control unit 705 and buffer memory 709 
included in the control unit 702 are the same as those of the 
command analysis unit 303, clock control unit 305 and buffer 

25 memory 309 of Embodiment 1, and therefore their descriptions 
are omitted here. 

(1) External IF Unit 701 and Card IF Units 710, 711, 712 
and 713 



information between an external apparatus and the control unit 
702, like the external IF unit 301 of the memory card 300 
according to Embodiment 1. The external IF unit 701 also 
5 receives electric power supplied from the external apparatus 
and outputs the received power to each circuit constituting the 
memory card drive 700. 

[0150] The card IF units 710, 711, 712 and 713 are connected 

to the memory cards 810, 811, 812 and 813, respectively, and 

10 input and output various information between the memory cards 
810, 811, 812 and 813 and the memory control units 730, 731, 
732 and 733. In addition, the card IF units 710, 711, 712 and 
713 receive a clock signal from the clock control unit 705 via 
the memory control units 730, 731, 732 and 733, and supply the 

15 received clock signal to the memory cards 810, 811, 812 and 813. 
[0151] Note that the data input and output speeds between 

the external IF unit 701 and the external apparatus are 
sufficiently fast, as compared with those between the card IF 
units 710, 711, 712 and 713 and the memory cards 810, 811, 812 

20 and 813. 

(2) Control Information Storage Unit 708 
The control information storage unit 708 stores therein, 
as shown in FIG. 17: a write current consumption value Iw; a 
read current consumption value Ir; the maximum number of cards 

25 Nmax and a control current value a. 

[0152] The write current consumption value Iw is the amount 

of current consumed by one group of a memory card, a card IF 
unit and a memory control unit when data is written to the memory 



card placed in the memory card drive 700. The read current 
consumption value Ir is the amount of current consumed by one 
group of a memory card, a card IF unit and a memory control unit 
when data is read from the memory card. 
5 [0153] The maximum number of cards Nmax is the number of 

memory cards that can be attached to the memory card drive 700, 
i.e. the number of memory card slots . In the present embodiment , 
Nmax =4 . 

The control current value a is the sum of the consumption 
10 current for operating individual circuits other than the memory 

cards, card IF units and memory control units. 

[0154] (3) Memory Control Units 730, 731, 732 and 733 

The memory control unit 730 receives a clock signal from 

the clock control unit 705 and supplies the received clock signal 
15 to the memory card 810 via the card IF unit 710. 

The memory control unit 730 detects, via the card IF unit 

710, the memory card 810 being placed in and taken out. 

[0155] The memory control unit 730 receives from the 

parallel control unit 704 a write direction and memory addresses 
20 indicating sectors for data writing. In addition, the memory 

control unit 730 receives a read direction and memory addresses 

from the parallel control unit 704. 

Receiving a write direction and memory addresses, the 

memory control unit 73 0 transfers one data block from the buffer 
25 memory 709 via the card IF unit 710 to a sector corresponding 

to one of the received memory addresses in the memory card 810. 

After completing the transfer, the memory control unit 73 0 

outputs to the parallel control unit 704 an end signal indicating 



that writing one data block is completed. 

[0156] Receiving a read direction and memory addresses , the 

memory control unit 730 transfers a data block stored in a sector 
corresponding to one of the received memory addresses from the 
5 memory card 810 via the card IF unit 710 to the buffer memory 
709. After completing the transfer, the memory control unit 
730 outputs to the parallel control unit 704 an end signal 
indicating that writing one data block is completed. 

In the same manner as the memory control unit 730, the 
10 memory control units 731 to 733 respectively control data input 
and output to/from the memory cards 811 to 813 via the card IF 
units 711 to 713. 

[0157] (4) Parallel Control Unit 704 

The parallel control unit 704 comprises, as shown in FIG. 
15 18: a command execution unit 721; a parallel computation unit 

722 and a memory number computation unit 723. 

The structure and operations of the parallel control unit 

704 are similar to those of the parallel control unit 304 

according to Embodiment 1. Accordingly, the following 
20 describes in detail only different aspects of the parallel 

control unit 704, leaving out features shared with the parallel 

control unit 304. 

[0158] (4-1) Parallel Computation Unit 722 

The parallel computation unit 722 performs a computation 
25 similar to that performed by the parallel computation unit 322 
of Embodiment 1, using the maximum number of cards Nmax in place 
of the number of memories N. The detailed operations are similar 
to those of the parallel computation unit 322, and the 



description is therefore omitted here. 

(4-2) Memory Number Computation Unit 723 
Since the detailed operations of the memory number 
computation unit 723 are similar to those of the memory number 
5 computation unit 323 , only a brief explanat ion i s provided here . 
Note that, in the present embodiment, the memory numbers "0" 
to "4" correspond to the memory cards 810 to 813, respectively. 
[0159] The memory number computation unit 723 receives the 

start sector number and the number of sectors from the command 
10 execution unit 721, and is directed to calculate the memory 
numbers . 

Directed to calculate the memory numbers, the memory 
number computation unit 723 computes (Eq. 4) and {Eq. 5) , using 
the maximum number of memories Nmax in place of the number of 

15 memories N , for obtaining the memory numbers and the sector 
numbers. Subsequently, the memory number computation unit 723 
generates a memory table including the calculated sector numbers 
and memory numbers as well as memory addresses, each of which 
is an address in memory cards corresponding to a different one 

20 of the memory numbers . 

[016 0] After generating the memory table , the memory number 

computation unit 723 outputs to the command execution unit 721 
an computation end signal indication that the computation of 
memory numbers is completed. 

25 (4-3) Command Execution Unit 721 

The command execution unit 721 receives a variety of 
commands output from an external apparatus and analyzed by the 
command analysis unit 703. 



[0161] When a received command is one for requesting the 

available supply current value, the command execution unit 721 
performs initialization, which is the same process performed 
by the command execution unit 321 according to Embodiment 1, 
5 and receives from the parallel computation unit 722 a 
computation end signal indicating that the computation of the 
number of parallel write memory cards Nw and the number of 
parallel read memory cards Nr is finished properly. 

When a received command is a write command indicating data 

10 writing, the command execution unit 721 receives data blocks 
from the external apparatus and directs data writing to each 
memory control unit in the same procedure of <Writing Process> 
performed by the command execution unit 321 of Embodiment 1, 
and thus performs write operations on Nw pieces of memory cards 

15 in parallel. 

[0162] When a received command is a read command indicating 

data reading, the command execution unit 721 directs each memory 
control unit to read out data in the same procedure of <Reading 
Process> performed by the command execution unit 321 of 

20 Embodiment 1, and thus reads data from Nr pieces of memory cards 
in parallel. 

3.3 Summary and Advantageous Effects 

As has been described above, the memory card drive 700 of 
the present embodiment obtains the available supply current 
25 value of an external apparatus to which the memory card drive 
700 is connected, and calculates, for data reading or for data 
writing, the number of memory cards allowed to operate in 
parallel within the obtained available supply current value. 



[0163] Receiving a write command from the external 

apparatus, the memory card drive 700 operates the calculated 
Nw or fewer pieces of memory cards in parallel. When receiving 
a read command, the memory card drive 700 operates the calculated 
5 Nr or fewer pieces of memory cards in parallel. 

In this way, it is possible to perform data reading and 
writing at the highest possible speeds within the power supply 
capacity of a connected external apparatus, as in the case of 
the memory card 3 00 of Embodiment 1. 
10 3.4 Modified Examples of Embodiment 3 

(1) The memory card drive 700 of Embodiment 3 controls the 
current consumption value of the memory card drive 700 to be 
no more than the available supply current value Iok of the 
external apparatus by calculating the number of memory cards 

15 Nw and Nr allowed to operate in parallel within the available 
supply current value Iok and restricting the number of parallel 
operating memory cards up to Nw or Nr. 

[0164] As described in Embodiment 2, however, the current 

consumption value may be limitd up to the available supply 
20 current value by changing the operating frequency for data 
reading . 

(2) In Embodiment 3, the supply of the clock signal to 
nonoperating memory cards can be stopped. 

In this case, the memory control unit 730 does not supply 
25 a clock signal received from the clock control unit 705 to the 
memory card 810. 

[0165] When receiving a write direction and memory numbers 

from the command execution unit 721, the memory control unit 



730 starts supplying a clock signal to the memory card 810. The 
memory control unit 73 0 subsequently starts transferring a data 
block from the buffer memory 709 to the memory card 810. When 
the transfer of the data block is finished, the memory control 
5 unit 730 outputs an end signal to the command execution unit 
721 in the parallel control unit 704, and stops the supply of 
the clock signal to the memory card 810. 

[0166] When receiving a read direction from the command 

execution unit 721 as well, the memory control unit 730 supplies 
10 a clock signal to the memory card 810 only during the transfer 
of a data block. 

The memory control units 731 to 733 also perform similar 
control operations over the memory cards 811 to 813, 
respectively . 

15 In this way, the memory card drive 700 supplies a clock 

signal only to operating memory cards, and stops supplying the 
clock signal to nonoperating memory cards. 

[0167] Even if not performing data reading and writing, the 

control units of the memory cards 810 to 813 carry out predefined 

20 operations when receiving a clock signal and therefore consume 
electric power. Accordingly, stopping the supply of the clock 
signal to memory cards not performing data writing or reading 
leads to a cut in the power consumption by the amount otherwise 
consumed by these nonoperating memory cards. 

25 {3) The above embodiment describes a situation where the 

memory card drive 700 is used with four memory cards placed 
therein; however, three or fewer memory cards may be used 
instead. 



[0168] In this case, the command execution unit 721 detects , 

via the memory control units and card IF units, the memory cards 
being placed in and taken out, and stores therein the number 
of memory cards n currently attached to the memory card drive 
5 700. Additionally, the command execution unit 721 associates 
the attached memory cards with card numbers. 

For instance, in the case where the memory card 811 is not 
placed in the memory card drive 700, the command execution unit 
721 associates the memory card 810 with the card number "0", 
10 the memory card 812 with the card number "1", and the memory 
card 813 with the card number "3" . 

[0169] When receiving a read command or a write command, 

the command execution unit 721 outputs to the memory number 
computation unit 723 the number of attached memory cards n 
15 together with the start sector number and the number of sectors. 

The memory number computation unit 723 generates a memory 
table using n in place of Nmax . 

This enables high-speed data input and output according 
to the number of attached memory cards, and improves user 
20 convenience since the user can freely choose the number of memory 
cards to be placed in the memory card drive 700. 

4. Other Modifications 

While the present invention has been illustrated and 
described in conjunction with Embodiments 1 to 3 , it should be 
25 understood that the present invention is not confined to these 
embodiments, and the following modifications are also within 
the scope of the present invention. 

[0170] (1) in Embodiments 1 and 2 above, the memory cards 



300 and 600 are respectively equipped with four flash memories, 
however, the present invention is not limitd to flash memories 
and may employ other recording devices instead. MRAMs 
{Magnetoresistive Random Access Memories) and ferroelectric 
5 memories are examples of such devices. 

(2) In Embodiment 3 and the modified examples thereof, the 
memory cards placed in the memory card drive 700 are for example 
SD memory cards, ATA flash cards or the like. 
[0171] (3) In Embodiment 3 and the modified examples thereof , 

10 the memory card drive 700 prestores therein a set of write and 
read current consumption values Ir and Iw for one type of memory 
cards to be placed therein. However, the memory card drive 700 
may prestore multiple sets of write and read current consumption 
values Iw and Ir for different types of memory cards. 

15 For instance, the memory card drive 700 may prestore write 

and read current consumption values Iws and Irs for SD memory 
cards and write and read current consumption values Iwa and Ira 
for ATA flash cards. Here, the memory card drive 700 determines 
a type of memory cards placed therein, and selects and uses 

20 either set of the write and read current consumption values — Iws 
and Irs, or Iwa and Ira. 

[0172] (4) In Embodiment 3, the memory card drive 700 is 

provided as an outside device to an external apparatus ; however, 
it may be housed in the external apparatus . 
25 (5) In Embodiment 2, the clock control unit 605 changes 

the clock frequency using a PLL; however, a frequency divider 
may be used instead. 

(6) The consumption current of the memory cards 300 and 
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600 is adjusted by changing the number of flash memories 
operating in parallel in Embodiment 1 while changing the 
operating frequency of flash memories in Embodiment 2 . However 
combining these features, the present invention may adjust the 
5 consumption current by changing both the number of parallel 
operating flash memories and the operating frequency of the 
flash memories . 

[0173] (7) The present invention may be a method of 

accomplishing Embodiments 1 to 3 and the modified examples 
10 above . 

(8) The present invention may be a computer program that 
achieves the method by a computer, or may be a digital signal 
representing the computer program. 

The present invention may also be achieved by a 

15 computer-readable recording medium, such as a flexible disk, 
a hard disk, a CD-ROM, a MO, a DVD, a DVD-ROM, a DVD-RAM, a BD 
(Blu-ray Disc) , or a semiconductor memory, on which the 
above-mentioned computer program or digital signal is recorded. 
The present invention may also be the computer program or the 

20 digital signal recorded on such a storage medium. 

[0174] The present invention may also be the computer 

program or digital signal to be transmitted via networks, as 
represented by telecommunications, wire/wireless 

communications, and the Internet, or via data broadcasting. 

25 The present invention may also be a computer system having 

a microprocessor and memory, wherein the memory stores the 
computer program and the microprocessor operates according to 
the computer program. 



[0175] The computer program or digital signal may be 

recorded on the above storage medium and transferred to an 
independent computer system, or alternatively, may be 
transferred to an independent computer system via the above 
5 network. Then, the independent computer system may execute the 
computer program or digital signal . 

(9) The present invention includes a structure in which 
two or more of the above embodiments and modifications are 
combined . 
10 [Industrial Applicability] 

[0176] The present invention is operationally, 

continuously and repeatedly applicable in: industries 
producing recording media and input-and-output apparatuses for 
writing and reading a variety of digital data to/from recording 
15 media; industries manufacturing electric apparatuses for 
accessing recording media via the input-and-output 
apparatuses; and industries producing, processing, recording 
and selling a variety of digital data by using the electric 
apparatuses, recording devices and recording media. 
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ABSTRACT 



[Problem] As to a memory card drive for operating 
multiple memory cards in parallel and executing high speed 
reading and writing, the amount of current supplied to the memory 
card drive varies among apparatuses connected and supplying 
electric power to the memory card drive due to their different 
capabilities, and therefore apparatuses applicable to the 
memory card drive are limitd. 

[Means for Solving the Problem] In a recording device 
having one or more semiconductor memories mounted thereon, the 
number of semiconductor memories operating in parallel is 
restricted according to the available supply current of an 
accessing apparatus to which the recording device is attached. 

[Selected Drawing] FIG . 5 
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